W1375

# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

2000-250712

(43)Date of publication of application: 14.09.2000

(51)Int.CI.

G06F 3/06

(21)Application number: 11-053611

(71)Applicant: HITACHI LTD

(22)Date of filing:

02.03.1999

(72)Inventor: FUJIMOTO KAZUHISA

# (54) DISK ARRAY CONTROLLER

## (57)Abstract:

PROBLEM TO BE SOLVED: To provide a disk array controller which reduces access time from an interface part with a host computer and an interface part with a magnetic disk drive to a cache memory part and has high data transfer throughput.

SOLUTION: A channel IF part 11 and a disk IF part 12 are connected to cache memory part 14 through a selector part 13. When accesses of a prescribed number or more from the part 11 or 12 compete, the part 3 selects the prescribed number of access paths. Respective microprocessors in the parts 11 and 12 are connected to a memory controller 105 in the part 14 with a control line, and the controller 105 performs an arbitration operation occurring in the part 13. Thus, it is possible to reduce waiting time due to access contention.



# LEGAL STATUS

[Date of request for examination]

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

Copyright (C); 1998,2003 Japan Patent Office

# (19)日本国特許庁 (JP) (12) 公開特許公報 (A)

(11)特許出願公開番号 特開2000-250712 (P2000-250712A)

(43)公開日 平成12年9月14日(2000.9.14)

(51) Int.Cl.7 G06F 3/06 識別記号 301 540

FΙ G06F 3/06

テーマコード(参考) 301G 5B065

540

審査請求 未請求 請求項の数6 OL (全 15 頁)

(21)出願番号

特願平11-53611

(22)出願日

平成11年3月2日(1999.3.2)

(71)出願人 000005108

株式会社日立製作所

東京都千代田区神田駿河台四丁目6番地

(72)発明者 藤本 和久

東京都国分寺市東恋ケ窪一丁目280番地

株式会社日立製作所中央研究所内

(74)代理人 100068504

弁理士 小川 勝男

Fターム(参考) 5B065 BA01 CA12 CA30 CE11

### (54) 【発明の名称】 ディスクアレイ制御装置

#### (57)【要約】

【課題】 ホストコンピュータとのインターフェース部 及び磁気ディスク装置とのインターフェース部からキャ ッシュメモリ部へのアクセス時間を短縮し、データ転送 スループットの高いディスクアレイ制御装置を提供す る。

【解決手段】 チャネル [ F部 1 1 及びディスク [ F部 12と、キャッシュメモリ部14との間をセレクタ部1 3を介して接続する。該セレクタ部は、チャネル I F部 11又はディスク I F部12から所定数以上のアクセス が競合した場合、所定数のアクセスパスを選択する。チ ャネル I F部11及びディスク I F部12内の各マイク ロプロセッサと、キャッシュメモリ部14内のメモリコ ントローラ105とを制御線で接続し、上記セレクタ部 で生ずる調停動作を、該メモリコントローラで行う。

【効果】 アクセス競合による待ち時間を減らすことが 可能となる。

**23** 1



#### 【特許請求の範囲】

【請求項1】それぞれが、ホストコンピュータとのインターフェース部と、ホストコンピュータに対する入出力を制御するマイクロプロセッサとを有する複数のチャネルインタフェース部と、

それぞれが、ディスク装置とのインターフェース部と、ディスク装置に対する入出力を制御するマイクロプロセッサとを有する複数のディスクインタフェース部と、前記ディスク装置とのインターフェース部に接続されるディスク装置内に格納されるデータを一時的に格納するメモリモジュールと、前記メモリモジュールへのアクセスを制御するメモリコントローラとを有するキャッシュメモリ部と、

前記複数のチャネルインタフェース部と、前記複数のディスクインタフェース部と、前記キャッシュメモリ部と に接続され、前記複数のチャネルインタフェース部及び 前記複数のディスクインタフェース部から前記キャッシュメモリ部へのアクセス要求を実行するセレクタ部と、 前記複数のチャネルインタフェース部及び前記複数のディスクインタフェース部内の各マイクロプロセッサと、 前記メモリコントローラとを接続する複数の制御線、と を有することを特徴とするディスクアレイ制御装置。

【請求項2】前記メモリコントローラは、前記複数の制御線を介して、前記複数のチャネルインタフェース部又は前記複数のディスクインタフェース部内の各マイクロプロセッサからアクセス要求を受信し、そのアクセス要求が競合した場合に、調停を行う手段を有することを特徴とする請求項1に記載のディスクアレイ制御装置。

【請求項3】それぞれが、ホストコンピュータとのインターフェース部と、ホストコンピュータに対する入出力を制御するマイクロプロセッサとを有する複数のチャネルインタフェース部と、

それぞれが、ディスク装置とのインターフェース部と、ディスク装置に対する入出力を制御するマイクロプロセッサとを有する複数のディスクインタフェース部と、前記ディスク装置とのインターフェース部に接続されるディスク装置内に格納されるデータを一時的に格納するメモリモジュールと、前記メモリモジュールへのアクセスを制御するメモリコントローラとを有するキャッシュメモリ部と、

前記複数のチャネルインタフェース部と、前記複数のディスクインタフェース部と、前記キャッシュメモリ部と に接続され、前記複数のチャネルインタフェース部及び 前記複数のディスクインタフェース部から前記キャッシュメモリ部へのアクセス要求を実行するセレクタ部とを 有し、

前記複数のチャネルインタフェース部の各チャネルイン タフェース部は、前記キャッシュメモリ部へのアクセス を制御するキャッシュメモリアクセス制御部を有し、 前記複数のディスクインタフェース部の各ディスクイン タフェース部は、前記キャッシュメモリ部へのアクセスを制御するキャッシュメモリアクセス制御部を有し、前記複数のチャネルインタフェース部の各チャネルインタフェース部の前記キャッシュメモリアクセス制御部と、前記複数のディスクインタフェース部のキャッシュメモリアクセス制御部と、前記メモリコントローラとを接続する複数の制御線、とを有することを特徴とするディスクアレイ制御装置。

【請求項4】前記メモリコントローラは、前記複数の制御線を介して、前記複数のチャネルインタフェース部又は前記複数のディスクインタフェース部内の各キャッシュメモリアクセス制御部からアクセス要求を受信し、そのアクセス要求が競合した場合に、調停を行う手段を有することを特徴とする請求項3に記載のディスクアレイ制御装置。

【請求項5】それぞれが、ホストコンピュータとのインターフェース部と、ホストコンピュータに対する入出力を制御するマイクロプロセッサとを有する複数のチャネルインダフェース部と、

それぞれが、ディスク装置とのインターフェース部と、ディスク装置に対する入出力を制御するマイクロプロセッサとを有する複数のディスクインタフェース部と、前記ディスク装置とのインターフェース部に接続されるディスク装置内に格納されるデータを一時的に格納するメモリモジュールと、前記メモリモジュールへのアクセスを制御するメモリコントローラとを有するキャッシュメモリ部と、

前記複数のチャネルインタフェース部と、前記複数のディスクインタフェース部と、前記キャッシュメモリ部と に接続され、前記複数のチャネルインタフェース部及び 前記複数のディスクインタフェース部から前記キャッシュメモリ部へのアクセス要求を実行するセレクタ部と、 前記複数のチャネルインタフェース部及び前記複数のディスクインタフェース部内の各マイクロプロセッサと、 前記セレクタ部とを接続する複数の制御線、とを有する ことを特徴とするディスクアレイ制御装置。

【請求項6】前記セレクタ部は、前記複数の制御線を介して、前記複数のチャネルインタフェース部又は前記複数のディスクインタフェース部内の各マイクロプロセッサからアクセス要求を受信し、そのアクセス要求が競合した場合に、調停を行う手段を有することを特徴とする請求項5に記載のディスクアレイ制御装置。

#### 【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、データを複数の磁気ディスク装置に格納するディスクアレイ装置の制御装置に関する。

[0002]

【従来の技術】半導体記憶装置を記憶媒体とするコンピ

ュータの主記憶の I / O性能に比べて、磁気ディスクを記憶媒体とするディスクサブシステム(以下「サブシステム」という。)の I / O性能は 3 ~ 4 桁程度小さく、従来からこの差を縮めること、すなわちサブシステムの I / O性能を向上させる努力がなされている。サブシステムの I / O性能を向上させるための1つの方法として、複数の磁気ディスク装置でサブシステムを構成し、データを複数の磁気ディスク装置に格納する、いわゆるディスクアレイと呼ばれるシステムが知られている。

【0003】図2は、従来のディスクアレイの構成を示 す。ホストコンピュータ50とディスクアレイ制御装置 2との間のデータ転送を実行する複数のチャネル I F部 11と、磁気ディスク装置20とディスクアレイ制御装 置2間のデータ転送を実行する複数のディスク I F部1 2と、磁気ディスク装置20のデータを一時的に格納す るキャッシュメモリ部14と、ディスクアレイ制御装置 2に関する制御情報(例えば、チャネル I F部及びディ スク I F部とキャッシュメモリ部14との間のデータ転 送制御に関する情報)を格納する共有メモリ部15とを 備え、キャッシュメモリ部14および共有メモリ部15 は全てのチャネル I F部 1 1 及びディスク I F部 1 2 か らアクセス可能な構成となっている。このディスクアレ イでは、チャネルIF部11及びディスクIF部12と 共有メモリ部15との間、及び、チャネルIF部11及 びディスクIF部12とキャッシュメモリ部14との間 は1対1に接続される。

【0004】チャネルIF部11は、ホストコンピュータ50と接続するためのインターフェース及びホストコンピュータ50に対する入出力を制御するマイクロプロセッサ(図示せず)を有している。また、ディスクIF部12は、磁気ディスク装置20と接続するためのインターフェース及び磁気ディスク装置20に対する入出力を制御するマイクロプロセッサ(図示せず)を有している。また、ディスクIF部12は、RAID機能の実行も行う。

【0005】図3は、他の従来のディスクアレイの構成を示す。ホストコンピュータ50とディスクアレイ制御装置3間のデータ転送を実行する複数のチャネルIF部11と、磁気ディスク装置20とディスクアレイ制御装置3間のデータ転送を実行する複数のディスクIF部2と、磁気ディスク装置20のデータを一時的に格納するキャッシュメモリ部14と、ディスクアレイ制御装置3に関する制御情報(例えば、チャネルIF部及びディスクIF部とキャッシュメモリ部14との間のデータ転送制御に関する情報)を格納する共有メモリ部15を備え、各チャネルIF部11及びディスクIF部12と共有メモリ部15間は共有バス130で接続され、各チャネルIF11部及びディスクIF部12とキャッシュメモリ部14間は共有バス131で接続される。

[0006]

【発明が解決しようとする課題】ディスクアレイシステムに対する高性能化要求に対して、これまでは、ディスクアレイ制御装置の大規模化や構成要素の高速化、例えばチャネルIF部及びディスクIF部内のプロセッサ数やキャッシュメモリ容量の増大、高性能プロセッサの適用、内部バス幅の拡大やバス転送能力の向上などで対応してきた。しかしながら、第3図に示した従来技術では、内部バスの転送能力がシステムの大規模化および性能向上に追従するのが困難になりつつある。

【0007】そこで内部バス性能を向上させて高いメモリアクセス性能を得るために、第2図に示した従来技術のように、チャネルIF部及びディスクIF部とキャッシュメモリ及び共有メモリ間を1:1に接続する方法が考えられる。この方法によれば、メモリに接続したアクセスパス数に比例して内部バス性能が増加する。しかしながら、搭載するプロセッサ数の増大に比例して、共有メモリおよびキャッシュメモリへのアクセス要求も増加する。そのため、内部バス性能を最大限に引き出すために、各チャネルIF部、ディスクIF部ー共有メモリ、キャッシュメモリ間のアクセスを効率的に制御する必要がある。

【0008】本発明の目的は上述の課題を解消し、チャネルIF部、ディスクIF部ーキャッシュメモリ間のアクセスパスを効率的に使用し、キャッシュメモリへのデータ転送スループットの高いディスクアレイ制御装置を提供することにある。

[0009]

【課題を解決するための手段】上記目的は、それぞれ が、ホストコンピュータとのインターフェース部と、ホ ストコンピュータに対する入出力を制御するマイクロプ ロセッサとを有する複数のチャネルインタフェース部 と、それぞれが、ディスク装置とのインターフェース部 と、ディスク装置に対する入出力を制御するマイクロプ ロセッサとを有する複数のディスクインタフェース部 と、前記ディスク装置とのインターフェース部に接続さ れるディスク装置内に格納されるデータを一時的に格納 するメモリモジュールと、前記メモリモジュールへのア クセスを制御するメモリコントローラとを有するキャッ シュメモリ部と、前記複数のチャネルインタフェース部 と、前記複数のディスクインタフェース部と、前記キャ ッシュメモリ部とに接続され、前記複数のチャネルイン タフェース部及び前記複数のディスクインタフェース部 から前記キャッシュメモリ部へのアクセス要求を実行す るセレクタ部と、前記複数のチャネルインタフェース部 及び前記複数のディスクインタフェース部内の各マイク ロプロセッサと、前記メモリコントローラとを接続する 複数の制御線とを有することを特徴とするディスクアレ イ制御装置により達成される。

【0010】望ましくは、前記メモリコントローラは、 前記複数の制御線を介して、前記複数のチャネルインタ フェース部又は前記複数のディスクインタフェース部内 の各マイクロプロセッサからアクセス要求を受信し、そ のアクセス要求が競合した場合に、調停を行う手段を有 する。

【0011】また、上記目的は、それぞれが、ホストコ ンピュータとのインターフェース部と、ホストコンピュ ータに対する入出力を制御するマイクロプロセッサとを 有する複数のチャネルインタフェース部と、それぞれ が、ディスク装置とのインターフェース部と、ディスク 装置に対する入出力を制御するマイクロプロセッサとを 有する複数のディスクインタフェース部と、前記ディス ク装置とのインターフェース部に接続されるディスク装 置内に格納されるデータを一時的に格納するメモリモジ ュールと、前記メモリモジュールへのアクセスを制御す るメモリコントローラとを有するキャッシュメモリ部 と、前記複数のチャネルインタフェース部と、前記複数 のディスクインタフェース部と、前記キャッシュメモリ 部とに接続され、前記複数のチャネルインタフェース部 及び前記複数のディスクインタフェース部から前記キャ ッシュメモリ部へのアクセス要求を実行するセレクタ部 とを有し、前記複数のチャネルインタフェース部の各チ ャネルインタフェース部は、前記キャッシュメモリ部へ のアクセスを制御するキャッシュメモリアクセス制御部 を有し、前記複数のディスクインタフェース部の各ディ スクインタフェース部は、前記キャッシュメモリ部への アクセスを制御するキャッシュメモリアクセス制御部を 有し、前記複数のチャネルインタフェース部の各チャネ ルインタフェース部の前記キャッシュメモリアクセス制 御部と、前記複数のディスクインタフェース部の各ディ スクインタフェース部のキャッシュメモリアクセス制御 部と、前記メモリコントローラとを接続する複数の制御 線とを有することを特徴とするディスクアレイ制御装置 により達成される。

【0012】望ましくは、前記メモリコントローラは、前記複数の制御線を介して、前記複数のチャネルインタフェース部又は前記複数のディスクインタフェース部内の各キャッシュメモリアクセス制御部からアクセス要求を受信し、そのアクセス要求が競合した場合に、調停を行う手段を有する。

【0013】また、上記目的は、それぞれが、ホストコンピュータとのインターフェース部と、ホストコンピュータに対する入出力を制御するマイクロプロセッサとを有する複数のチャネルインタフェース部と、それぞれが、ディスク装置とのインターフェース部と、ディスク装置に対する入出力を制御するマイクロプロセッサとを有する複数のディスクインタフェース部と、前記ディスク装置とのインターフェース部に接続されるディスク装置内に格納されるデータを一時的に格納するメモリモジュールと、前記メモリモジュールへのアクセスを制御するメモリコントローラとを有するキャッシュメモリ部

と、前記複数のチャネルインタフェース部と、前記複数のディスクインタフェース部と、前記キャッシュメモリ部とに接続され、前記複数のチャネルインタフェース部及び前記複数のディスクインタフェース部から前記キャッシュメモリ部へのアクセス要求を実行するセレクタ部と、前記複数のチャネルインタフェース部及び前記複数のディスクインタフェース部内の各マイクロプロセッサと、前記セレクタ部とを接続する複数の制御線とを有することを特徴とするディスクアレイ制御装置により達成される。

【0014】望ましくは、前記セレクタ部は、前記複数の制御線を介して、前記複数のチャネルインタフェース部又は前記複数のディスクインタフェース部内の各マイクロプロセッサからアクセス要求を受信し、そのアクセス要求が競合した場合に、調停を行う手段を有する。

#### [0015]

【発明の実施の形態】本発明の実施例について、以下詳細に説明する。

【0016】(実施例1)図1に、本発明の一実施例を示す。

【0017】図1に、本発明の一実施例を示す。

【0018】ディスクアレイ制御装置1は、ホストコンピュータ50との2つのインターフェース部(チャネルIF部)11と、磁気ディスク装置20との2つのインターフェース部(ディスクIF部)12と、2つのセレクタ部13と、2つのキャッシュメモリ部14と、2つの共有メモリ部15と、アクセスパス0:135と、アクセスパス1:136と、アクセスパス2:137とを有する。

【0019】図13を用いて、チャネルIF部11の構成を説明する。チャネルIF部11は、ホストコンピュータ50との2つのIF(ホストIF)102と、ホストコンピュータ50との2つのIF(ホストIF)102と、ホストコンピュータ50に対する入出力を制御する2つのマイクロプロセッサ101と、キャッシュメモリ部14へのアクセスを制御するアクセス制御部(CMアクセス制御部)104を有し、ホストコンピュータ50とキャッシュメモリ部14間のデータ転送を実行する。マイクロプロセッサ101及びホストIF102は内部バス106によって接続され、CMアクセス制御部104は2つのホストIF102に直接接続されている。2つのマイクロプロセッサ101とメモリコントローラとの間は、制御線216で接続されている。

【0020】ディスクIF部12は、図13で説明したチャネルIF部11の構成と同様である。ディスクIF部12は、磁気ディスク装置20との2つのIF(ドライブIF)103と、磁気ディスク装置20に対する入出力を制御する2つのマイクロプロセッサ101と、キャッシュメモリ部14への1つのアクセス制御部(CMアクセス制御部)104を有し、磁気ディスク装置20とキャッシュメモリ部14間のデータ転送を実行する。

マイクロプロセッサ101及びドライブIF103は内部バス106によって接続され、CMアクセス制御部104は2つのドライブIF103に直接接続されている。2つのマイクロプロセッサ101とメモリコントローラとの間は、制御線216で接続されている。また、ディスクIF部はRAID機能の実行も行う。

【0021】ここで、上記個数は一実施例に過ぎず、個数を上記に限定するものではない。

【0022】キャッシュメモリ部14は、メモリコントローラ105とメモリモジュール106を有し、磁気ディスク装置20へ記録するデータや、そのデータ及びシステム内の管理情報等を格納する。

【0023】マイクロプロセッサ101は、キャッシュメモリ部14へのアクセス時、制御線6:216を使用してメモリコントローラ105へアクセス要求を送出する。メモリコントローラ105は、各マイクロプロセッサ101からのアクセス要求にもとづいてアービトレーションを行い、メモリへのアクセス権を獲得したマイクロプロセッサ101な、メモリコントローラ105からアクセス承認を受けると、キャッシュメモリ部14へのアクセスを開始する。

【0024】セレクタ部13には、2つのチャネル I F 部11、2つのディスク I F 部12 からそれぞれ1本ずつ、計4本のアクセスパス0:135が接続されている。また、セレクタ部13には、2つのキャッシュメモリ部14へのアクセスパス1:136が1本ずつ、計2本接続されている。

【0025】アクセスパス0:135とアクセスパス1:136の間には上記のようなパス数の関係があるため、セレクタ部13ではチャネル I F部11 及びディスク I F部12 からの4 本のアクセスパス0:135 からの要求の内、キャッシュメモリ部14へのアクセスパス1:136 の数に相当する2 個だけを選択して実行する機能を持つ。

【0026】ここで、上記個数は一実施例に過ぎず、個数を上記に限定するものではない。1つのセレクタ部13からキャッシュメモリ部14へ接続されるアクセスパスの数を、チャネルIF部11及びディスクIF部12から1つのセレクタ部13に接続されるアクセスパスの数より少なくし、チャネルIF部11とディスクIF部12の合計数よりもセレクタ部13の数が少なくなるように上記個数を設定すると、キャッシュメモリ部14へ接続されるアクセスパス数を削減することができる。キャッシュメモリ部14のLSIピンネック及びパッケージのコネクタネックという問題が生じた場合、上記のようにすることで、LSIのピンネック及びパッケージのコネクタネックを解消することができる。

【0027】図6は、CMアクセス制御部104内の構成を示している。CMアクセス制御部104は、セレク

タ302と、キャッシュメモリ部14に繋がるアクセスパス0:135とのパスIF301と、データのエラーチェック部300と、データ転送制御部310を有する。セレクタ302の2つのポートはデータ線210でホストIF102あるいはドライブIF103に接続される。また、セレクタ302のもう1つのポートはパスIF301に接続される。パスIF301はアクセスパス0:135でセレクタ部13に接続される。データ転送制御部310は、制御線1:211でホストIF102あるいはドライブIF103に接続され、制御線2:212でセレクタ部13内のデータ転送制御部310に接続される。また、データ転送制御部310は、セレクタ302の切り替えを行う。

【0028】図8は、セレクタ部13内の構成を示している。セレクタ部13は、チャネルIF部11、またはディスクIF部12に繋がるアクセスパス0:135とのパスIF301と、キャッシュメモリ部14に繋がるアクセスパス0:136とのパスIF301と、両者間を互いに接続するセレクタ304と、データのエララチェック部300と、CMアクセス制御部104から送出されたアドレス及びコマンドを解析するアドレスとびコマンドを解析するアドレスとびコマンドを解析するアドレスとびコマンドを解析するアドレスとびコマンドを解析するアドレスとびコマンドを解析するアドレスとびコマンドを解析するアドレスとびコマンドを解析する10は、データ転送制御部310に接続され、制御線4:214でキャッシュメモリ部14のメモリコントローラ105内を受しまた、データ転送制御部310は、セレクタ304の切り替えを行う。

【0029】図10は、キャッシュメモリ部14内の構 成を示している。キャッシュメモリ部14は、メモリコ ントローラ105とメモリモジュール106を有する。 メモリコントローラ105は、セレクタ部13に繋がる アクセスパス1:136とのパスIF301と、メモリ モジュール106とのメモリIF308と、両者間を互 いに接続するセレクタ302と、データのエラーチェッ ク部300と、メモリモジュール106へのアクセスを 制御するメモリ制御部307と、CMアクセス制御部1 0 4から送出されたアドレス及びコマンドを解析するア ドレス (adr)、コマンド (cmd) 解析部305 と、アービタ306と、データ転送制御部310を有す る。アービタ306は、制御線6:216で各マイクロ プロセッサ101へ接続される。データ転送制御部31 0は、制御線4:214でセレクタ部13内のデータ転 送制御部310に接続される。また、データ転送制御部 310は、セレクタ302の切り替えを行う。

【0030】次に、キャッシュメモリ部14へのアクセス時の手順について述べる。キャッシュメモリ部14へアクセスする場合、チャネルIF部11またはディスクIF部12内のマイクロプロセッサ101は、アクセスするキャッシュメモリ部14のメモリコントローラ10

5内のアーピタ306へ、制御線6:216を使用して、アクセス要求を送出する。

【0031】メモリコントローラ105内のアービタ306は、アービトレーションによって各マイクロプロセッサ101からのアクセス要求の内の1つを選択する。【0032】本実施例の構成(図1)では、キャッシュメモリ部14へのアクセス時に、CMアクセス制御部104、セレクタ部13、及びメモリコントローラ105の3個所でアクセスの競合が発生するため、それぞれの箇所でアービトレーションを行い、競合の解消をする必要がある。本発明の特徴は、それら3つのアービタ306においてまとめて行うことにある。これにより、アクセス競合による3回の待ち時間を1回に減らすことが可能となる。

【0033】アービタ306は、選択されたアクセス要求を出したマイクロプロセッサ101へ、制御線6:216を使用して、アクセス承認を返す。アクセス承認を受けたマイクロプロセッサ101は、ホストIF102あるいはドライブIF103へ、キャッシュメモリ部14へのアクセス開始を指示する。

【0034】アクセス開始の指示を受けたホストIF102あるいはドライブIF103は、制御線1:211によりCMアクセス制御部104内のデータ転送制御部310へアクセス開始を示す信号と、アクセス先のメモリコントローラ105を示す信号を送出する。データ転送制御部310は、2本の制御線1:211のどちらからアクセス開始の信号が来たかによって、セレクタ302を切り替え、制御線1:211によりホストIF102あるいはドライブIF103へアクセス承認の信号を返すとともに、制御線2:212によってセレクタ部13内のデータ転送制御部310へアクセス開始を示す信号と、アクセス先のメモリコントローラ105を示す信号を出す。

【0035】本実施例では、CMアクセス制御部104に2つのホストIF102あるいは2つのドライブIF103が繋がっている。しかし、CMアクセス制御部104からメモリコントローラ105へのアクセスルートは1つしかないため、メモリコントローラ105がメモリモジュール106へのアクセスを同時に複数処理できる機能を有する場合、アービタ306でのアービトる2つのホストIFあるいは2つのドライブIFを制御する2つのマイクロプロセッサ101の両方にアクセス制御部104に繋がるまるとMアクセス制御部104に繋がるまないようにする必要がある。CMアクセス制御部104に繋がるホストIF102あるいはドライブIF103の数と1つのCMアクセス制御部104から1つのメモリコントローラ105へのアクセスルートの数が等しい場合は、この限りではない。

【0036】また本実施例では、メモリコントローラ1

05が2つあるのに対してCMアクセス制御部104に繋がるアクセスパス0:135は1本であるため、CMアクセス制御部104から2つのメモリコントローラ105へ同時にアクセスすることが出来ない。したがって、2つのメモリコントローラ105内のアービタ306でのアービトレーション時には、もう一方のメモリコントローラ105内のアービタ306でのアービトレーション時には、もう一方のメモリコントローラ105内のアービタ306の情報を参約にて、同じCMアクセス制御部104に繋がる20のホストIFあるいは20のドライブIFを制御する20のホイクロプロセッサ101の両方にアクセス解御部104から20のメモリコントローラ105へ同時にアクセスすることが可能である場合は、この限りではない。

【0037】本実施例では、アービタ306で上記のような制約を考慮したアービトレーションを行わず、同じ CMアクセス制御部104に繋がる2つのホストIF102あるいは2つのドライブIF103を制御する2つのマイクロプロセッサ101が排他制御を行い、CMアクセス制御部104を同時に使用しないようにする。すなわち、上記2つのマイクロプロセッサ101が、同時にキャッシュメモリ部14ヘアクセス要求を出さないように排他制御を行う。

【0038】したがって、データ転送制御部310では、2本の制御線1:211の両方からアクセス開始の信号が来た場合はエラーとみなし、障害処理を行う。

【0039】ホストIF102あるいはドライブIF103は、アクセス承認を受けるとデータ線210を通してアドレス、コマンド、データ(データの書き込み時のみ)を送出する。СМアクセス制御部104は、送られてきたアドレス、コマンド、データ(データの書き込み時のみ)をセレクタ302、パスIF301を介して、セレクタ部13に繋がるアクセスパス0:135に送出する。

【0040】セレクタ部13内のデータ転送制御部310は、制御線2:212によってアクセス開始の信号と、アクセス先のメモリコントローラ105を示す信号を受けると、4本の制御線2:212のどれからアクセス開始の信号が来たかと、アクセス先のメモリコントローラ105を示す信号によって、セレクタ304を切り替え、制御線2:212によりCMアクセス制御部104内のデータ転送制御部310へアクセス承認の信号を返すとともに、制御線4:214によってメモリコントローラ105内のデータ転送制御部310へアクセス開始を示す信号と、アクセス先のメモリコントローラ105を示す信号を出す。

【0041】本実施例では、セレクタ部13と1つのメモリコントローラ105間にアクセスパス1:136が1本しかないため、アービタ306でのアービトレーション時には同じセレクタ部13に繋がるチャネルIF部

11及びディスク I F部 12内のマイクロプロセッサ 101の内の 1 つにのみアクセス承認を与えるようにする必要がある。セレクタ部 13 と 1 つのメモリコントローラ 105 間にアクセスパス 1:136 が複数本あり、メモリコントローラ 105 がそのアクセスパスの数に等しい要求を同時に処理できる場合は、それに等しい数のマイクロプロセッサ 101 へアクセス承認を与えることが出来る。

【0042】上記のような制御を行うため、データ転送制御部310では、4本の制御線2:212のうちの複数本から同一のメモリコントローラ105ヘアクセス開始の信号が来た場合はエラーとみなし、障害処理を行う。

【0043】セレクタ部13は、送られてきたアドレス、コマンド、データ(データの書き込み時のみ)をアクセスパス0:135に繋がるパス IF301、セレクタ304、アクセスパス1:136に繋がるパス IF301を介して、メモリコントローラ105に繋がるアクセスパス1:136に送出する。

【0044】また、送られてきたアドレス及びコマンドはメモリコントローラ105へ送出するとともに、アドレス(adr)、コマンド(cmd)解析部305へ取り込み、2つのメモリコントローラ105の内のどちらにアクセスするかを調べ、制御線212のアクセス先のメモリコントローラ105を示す信号と比較し、異なる場合はエラーとみなし障害処理を行う。

【0045】ここで、上記のように制御線によってアクセス先のメモリコントローラ105を示す信号を送らない場合は、ホストIF102またはドライプIF103は、最初にアドレスとコマンドだけを送出する。そして、セレクタ部13内のアドレス(adr)、コマンド(cmd)解析部305でアクセス先メモリコントローラ105を調べてセレクタ304を切り替えた後、アクセス承認がCMアクセス制御部104を経由して返ってきたのを確認した後、データを送出するという手順で処理を行う必要がある。

【0046】メモリコントローラ105内のデータ転送制御部310は、制御線4:214によってアクセス開始の信号と、アクセス先のメモリコントローラ105を示す信号を受けると、2本の制御線4:214のどちらからアクセス開始の信号が来たかによって、セレクタ302を切り替え、制御線4:214によりセレクタ部13内のデータ転送制御部310へアクセス承認の信号を返すとともに、メモリ制御部307へアクセス開始を示す信号を出す。

【0047】上記のような制御を行うため、データ転送制御部310では、2本の制御線4:214の両方からアクセス開始の信号が来た場合はエラーとみなし、障害処理を行う。

【0048】送られてきたアドレス、コマンドは、アド

レス (a d r)、コマンド (c m d) 解析部 3 0 5 へ取り込み、解析結果得られたメモリの制御情報をメモリ制御部 3 0 7 へ送出する。また、アクセス先メモリコントローラ 1 0 5 を調べ、自メモリコントローラと異なる場合はエラーとみなし障害処理を行う。

【0049】データの書き込み時は、アクセスパス1: 136を通して送られてきたデータをパス IF301、セレクタ302、メモリ IF308を介してメモリモジュール106へ書き込む。データの読み出し時は、メモリモジュール106からデータを読み出し、メモリ IF308、セレクタ302、パス IF301を介してアクセスパス1:136へ送出する。

【0050】メモリモジュール106へのアクセスが終了すると、データ転送制御部310においてアクセス状況を示すステータスを生成し、セレクタ部13、CMアクセス制御部104を経由して、ホストIF102またはドライブIF103へ送出する。

【0051】本実施例では、CMアクセス制御部104 のデータ転送制御部310は、セレクタ302を切り替 えた後、アクセス開始の信号をセレクタ部13に送出 し、アクセス承認をホストIF102あるいはドライブ IF103へ返すとしたが、そうした場合は、ホストI F102あるいはドライブIF103からアドレスが送 られてくる前に、セレクタ部13からアクセス承認が返 ってくるように、各部の処理時間を設定しなければなら ない。同様に、セレクタ部13においても、CMアクセ ス制御部104からアドレスが送られてくる前に、メモ リコントローラ105からアクセス承認が返ってくるよ うに、各部の処理時間を設定しなければならない。上記 のように出来ない場合は、CMアクセス制御部104及 びセレクタ部13にバッファを設けるか、セレクタ部1 3はメモリコントローラ105からアクセス承認が返っ てくるまでCMアクセス制御部104にアクセス承認を 返さず、同様にCMアクセス制御部104はセレクタ部 13からアクセス承認が返ってくるまでホスト IF 10 2またはドライプIF103にアクセス承認を返さない ようにする必要がある。

【0052】上記のように、3個所で発生する競合解消のためのアービトレーションをメモリコントローラ105内のアービタ306においてまとめて行うことにより、アクセス競合による3回の待ち時間を1回に減らすことが可能となる。それによって、キャッシュメモリ部14へのアクセス時間が短縮され、高いスループットのデータ転送を実現できる。

【0053】また、図12に示すように、チャネルIF部11、ディスクIF部12、キャッシュメモリ部14を、4つのスイッチ(SW)16で構成した相互結合網110で接続したディスクアレイ制御装置1においても、本実施例は有効であり、CMアクセス制御部104、SW16、メモリコントローラ105のそれぞれで

発生するアクセスの競合を解消するためのアービトレーションをメモリコントローラ105でまとめて行うことができる。それによって、キャッシュメモリ部14へのアクセス時間が短縮され、高いスループットのデータ転送を実現できる。

【0054】(実施例2)図4に、本発明の他の実施例を示す。

【0055】ディスクアレイ制御装置1は、チャネルI F部11、ディスクIF部12、セレクタ部13、キャッシュメモリ部14と、アクセスパス0:135、アクセスパス1:136を有する。

【0056】チャネルIF部11、ディスクIF部1 2、及びセレクタ部13の構成は、実施例1と同様であ 。

【0057】CMアクセス制御部104とメモリコントローラ105間は制御線3:213で接続される。CMアクセス制御部104は、キャッシュメモリ部14へのアクセス時、制御線3:213を使用してメモリコントローラ105へアクセス要求を送出する。メモリコントローラ105は、各CMアクセス制御部からのアクセス要求にもとづいてアービトレーションを行い、メモリへのアクセス権を獲得したCMアクセス制御部104へ、制御線3:213を使用してアクセス承認を返す。CMアクセス制御部104は、メモリコントローラ105からアクセス承認を受けると、キャッシュメモリ部14へのアクセスを開始する。

【0058】図7は、CMアクセス制御部104内の構 成を示している。CMアクセス制御部104は、セレク タ302と、キャッシュメモリ部14に繋がるアクセス パス0:135とのパスIF301と、アドレス、コマ ンド、及びデータを一時保存するパケットバッファ30 3と、データのエラーチェック部300と、データ転送 制御部310を有する。セレクタ302の2つのポート はデータ線210でホストIF102あるいはドライブ IF103に接続される。また、セレクタ302のもう 1つのポートはパスIF301に接続される。パスIF 301はアクセスパス0:135でセレクタ部13に接 続される。データ転送制御部310は、制御線1:21 1でホストIF102あるいはドライブIF103に接 続され、制御線2:212でセレクタ部13内のデータ 転送制御部310に接続され、さらに制御線213でメ モリコントローラ105内のデータ転送制御部310に 接続される。また、データ転送制御部310は、セレク タ302の切り替えを行う。

【0059】セレクタ部13内の構成は、図8に示す実施例1の構成と同様である。

【0060】キャッシュメモリ部14内の構成は、図10に示す実施例1の構成において、制御線6:216の代わりに、CMアクセス制御部104内のデータ転送制御部310に繋がる制御線3:213をアービタ306

に接続した構成とする。

【0061】次に、キャッシュメモリ部14へのアクセス時の手順について述べる。キャッシュメモリ部14へアクセスする場合、チャネルIF部11またはディスクIF部12内のマイクロプロセッサ101は、ホストIF102あるいはドライプIF103へ、キャッシュメモリ部14へのアクセス開始を指示する。

【0062】アクセス開始の指示を受けたホストIF102あるいはドライブIF103は、制御線1:211によりCMアクセス制御部104内のデータ転送制御部310へアクセス開始を示す信号と、アクセス先のメモリコントローラ105を示す信号を送出するとともに、データ線210を通してアドレス、コマンド、データを送出する。

【0063】 CMアクセス制御部104は、データ線210を通して送られてきたアドレス、コマンド、データ(データの書き込み時のみ)をパケットバッファ303に一時格納する。データ転送制御部310は、アービトレーションを行い、2つのホストIF102あるいは2つのドライブIF0うちのどちらに、キャッシュメモリ部14へのアクセス権を与えるかを決定する。その後、アクセス権を与えられたホストIF102あるいはドライブIF103がアクセスするキャッシュメモリ部14のメモリコントローラ105内のアービタ306へ、制御線3:213を使用して、アクセス要求を送出する。【0064】メモリコントローラ105内のアービタ306は、アービトレーションによって各CMアクセス制御部104からのアクセス要求の内の1つを選択する。

【0065】本実施例の構成(図1)では、キャッシュメモリ部14へのアクセス時に、CMアクセス制御部104、セレクタ部13、及びメモリコントローラ105の3個所でアクセスの競合が発生するため、それぞれの箇所でアービトレーションを行い、競合の解消をする必要がある。本発明の特徴は、それらのうち、セレクタ部13とメモリコントローラ105の2個所でのアービトレーションをメモリコントローラ105内のアービタ306においてまとめて行うことにある。これにより、アクセス競合による3回の待ち時間を2回に減らすことが可能となる。

【0066】本実施例は、実施例1のように全てのマイクロプロセッサ101からの制御線6:216をメモリコントローラ105に接続することが、メモリコントローラ105を実装するLSIのピンネックにより不可能な場合に有効となる。

【0067】アービタ306は、選択されたアクセス要求を出したCMアクセス制御部104へ、制御線3:213を使用して、アクセス承認を返す。

【0068】アクセス承認を受けたCMアクセス制御部 104内のデータ転送制御部310は、セレクタ302 を切り替え、制御線2:212によってセレクタ部13 内のデータ転送制御部310へアクセス開始を示す信号と、アクセス先のメモリコントローラ105を示す信号を出す。アクセス承認がセレクタ部13から返ってきたら、パケットバッファ内のアドレス、コマンド、データ(書き込み時のみ)をセレクタ302、パスIF301を介して、アクセスパス0:135へ送出する。以降の処理手順は、実施例1で述べた手順と同様である。

【0069】本実施例では、セレクタ部13と1つのメモリコントローラ105間にアクセスパス1:136が1本しかないため、アービタ306でのアービトレーション時には同じセレクタ部13に繋がるCMアクセス制御部104の内の1つにのみアクセス承認を与えるようにする必要がある。セレクタ部13と1つのメモリコントローラ105間にアクセスパス1:136が複数本あり、メモリコントローラ105がそのアクセスパスの数に等しい要求を同時に処理できる場合は、それに等しい数のCMアクセス制御部104へアクセス承認を与えることが出来る。

【0070】本実施例においても実施例1と同様に、セレクタ部13において、CMアクセス制御部104からアドレスが送られてくる前に、メモリコントローラ105からアクセス承認が返ってくるように、各部の処理時間を設定しなければならない。上記のように出来ない場合は、セレクタ部13にバッファを設けるか、セレクタ部13はメモリコントローラ105からアクセス承認が返ってくるまでCMアクセス制御部104にアクセス承認を返さないようにする必要がある。

【0071】LSIのピンネックにより、全てのマイクロプロセッサ101からの制御線をメモリコントローラ105に接続できない場合は、上記のように、セレクタ部13及びメモリコントローラ105の2個所で発生する競合解消のためのアービトレーションをメモリコントローラ105内のアービタ306においてまとめて行うことにより、アクセス競合による3回の待ち時間を2回に減らすことが可能となる。それによって、キャッシュメモリ部14へのアクセス時間が短縮され、高いスループットのデータ転送を実現できる。

【0072】 (実施例3) 図5に本発明の他の実施例を示す。

【0073】 ディスクアレイ制御装置 1 は、チャネル 1 F部 1 1、ディスク 1 F部 1 2、セレクタ部 1 3、キャッシュメモリ部 1 4 と、アクセスパス 0:1 3 5、アクセスパス 1:1 3 6 を有する。

【0074】チャネルIF部11及びディスクIF部12の構成は、実施例1と同様である。

【0075】マイクロプロセッサ101とセレクタ部13間は制御線5:215で接続されている。マイクロプロセッサ101は、キャッシュメモリ部14へのアクセス時、制御線5:215を使用してセレクタ部13へアクセス要求を送出する。セレクタ部13は、各マイクロ

プロセッサ101からのアクセス要求にもとづいてアービトレーションを行い、メモリへのアクセス権を獲得したマイクロプロセッサ101へ、制御線5:215を使用してアクセス承認を返す。マイクロプロセッサ101は、セレクタ部13からアクセス承認を受けると、キャッシュメモリ部14へのアクセスを開始する。

【0076】CMアクセス制御部104内部の構成は、図6に示す実施例1の構成と同様である。

【0077】図9は、セレクタ部13内の構成を示して いる。セレクタ部13は、チャネルIF部11、または ディスク I F部12に繋がるアクセスパス0:135と のパス I F 3 0 1 と、キャッシュメモリ部 1 4 に繋がる アクセスパス1:136とのパスIF301と、両者間 を互いに接続するセレクタ304と、データのエラーチ エック部300と、チャネルIF部11、またはディス ク I F部 1 2 から送出されたアドレス及びコマンドを解 析するアドレス (adr)、コマンド (cmd) 解析部 305と、アービタ306と、データ転送制御部310 を有する。データ転送制御部310は、制御線2:21 2でCMアクセス制御部104内のデータ転送制御部3 10に接続され、制御線4:214でキャッシュメモリ 部14のメモリコントローラ105内のデータ転送制御 部310に接続される。また、データ転送制御部310 は、セレクタ304の切り替えを行う。アービタ306 には、マイクロプロセッサ101からの制御線5:21 5が接続される。本実施例では、チャネル I F部 1 1、 またはディスク I F部12に繋がるアクセスパス0:1 35とのIFポート301の数を4つ、キャッシュメモ リ部14に繋がるアクセスパス1:136とのパスIF 301の数を2つとした。実施例1の場合と同様に、上 記個数は一実施例に過ぎず、個数を上記に限定するもの ではない。

【0078】図11は、キャッシュメモリ部14内の構 成を示している。キャッシュメモリ部14は、メモリコ ントローラ105とメモリモジュール106を有する。 メモリコントローラ105は、セレクタ部13に繋がる アクセスパス1:136とのパスIF301と、メモリ モジュール106とのメモリIF308と、両者間を互 いに接続するセレクタ302とアドレス、コマンド、デ ータを一時格納するパケットバッファ303と、データ のエラーチェック部300と、メモリモジュール106 へのアクセスを制御するメモリ制御部307と、CMア クセス制御部104から送出されたアドレス及びコマン ドを解析するアドレス (adr)、コマンド (cmd) 解析部305と、データ転送制御部310を有する。デ ータ転送制御部310は、制御線4:214でセレクタ 部13内のデータ転送制御部310に接続される。ま た、データ転送制御部310は、セレクタ302の切り 替えを行う。本実施例では、セレクタ部13に繋がるア クセスパス1:136とのパスIF301の数を2つと

した。上記個数は一実施例に過ぎず、個数を上記に限定 するものではない。

【0079】次に、キャッシュメモリ部14へのアクセス時の手順について述べる。キャッシュメモリ部14へアクセスする場合、チャネルIF部11またはディスクIF部12内のマイクロプロセッサ101は、自身が実装されているチャネルIF部11またはディスクIF部12が繋がるセレクタ部13内のアービタ306へ、制御線5:215を使用して、アクセス要求を送出する。

【0080】セレクタ部13内のアービタ306は、アービトレーションによって各マイクロプロセッサ101からのアクセス要求の内の1つを選択する。

【0081】本実施例の構成(図1)では、キャッシュメモリ部14アクセス時に、CMアクセス制御部104、セレクタ部13、及びメモリコントローラ105の3個所でアクセスの競合が発生するため、それぞれの箇所でアービトレーションを行い、競合の解消をする必要がある。本発明の特徴は、それらのうち、CMアクセス制御部104及びセレクタ部13でのアービトレーションをセレクタ部13内のアービタ306においてまとめて行うことにある。これにより、アクセス競合による3回の待ち時間を2回に減らすことが可能となる。

【0082】本実施例は、実施例1のように全てのマイクロプロセッサ101からの制御線6:216をメモリコントローラ105に接続することが、メモリコントローラ105を実装するLSIのピンネックにより不可能な場合に有効となる。但し、セレクタ部13内のセレクタ304とアクセスパス1:136とのパスIF301の間、あるいはメモリコントローラ105内のパスIFとセレクタ302の間にパケットバッファ303を設ける必要がある。本実施例ではメモリコントローラ105内にパケットバッファ303を設ける。

【0083】このようにパケットバッファ303を設けるのは、セレクタ部13においてキャッシュメモリ部14に繋がるアクセスパス1:136の使用権を獲得しても、メモリコントローラ105においてメモリモジュール106へのアクセスの競合が発生して待ち時間が生じるためである。したがって、パケットバッファ303を設けないと、メモリモジュール106へのアクセス権を獲得できるまで、マイクロプロセッサ101はキャッシュメモリ部14へのアクセスを開始できず、その間アクセスパス0:135及びアクセスパス1:136を占有することになる。そのため、アクセスパスの使用効率が低下して、データ転送のスループットが下がる。

【0084】アービタ306は、選択されたアクセス要求を出したマイクロプロセッサ101へ、制御線5:215を使用して、アクセス承認を返す。アクセス承認を受けたマイクロプロセッサ101は、ホストIF102あるいはドライブIF103へ、キャッシュメモリ部14へのアクセス開始を指示する。

【0085】アクセス開始の指示を受けたホストIF102あるいはドライブIF103は、制御線1:211によりCMアクセス制御部104内のデータ転送制御部310へアクセス開始を示す信号と、アクセス先のメモリコントローラ105を示す信号を送出する。データ転送制御部310は、2本の制御線1:211のどちらからアクセス開始の信号が来たかによって、セレクタ302を切り替え、制御線1:211によりホストIF102あるいはドライブIF103へアクセス承認の信号を返すとともに、制御線2:212によってセレクタ部13内のデータ転送制御部310へアクセス開始を示す信号と、アクセス先のメモリコントローラ105を示す信号を出す。

【0086】本実施例では、CMアクセス制御部104に2つのホストIF102あるいは2つのドライブIF103が繋がっているが、CMアクセス制御部104からセレクタ部13へのアクセスルートは1つしかないため、アービタ306でのアービトレーション時には同じCMアクセス制御部104に繋がる2つのホストIFあるいは2つのドライブIFを制御する2つのマイクロプロセッサ101の両方にアクセス承認を与えないようにする必要がある。CMアクセス制御部104に繋がるホストIF102あるいはドライブIF103の数とセレクタ部13へのアクセスルートの数が等しい場合は、この限りではない。

【0087】アービタ306で上記のような制約を考慮したアービトレーションを行わない場合は、同じCMアクセス制御部104に繋がる2つのホストIF102あるいは2つのドライブIF103を制御する2つのマイクロプロセッサ101が排他制御を行い、CMアクセス制御部104を同時に使用しないようにする必要がある

【0088】上記のような制御を行った場合、データ転送制御部310では、2本の制御線1:211の両方からアクセス開始の信号が来た場合はエラーとみなし、障害処理を行う。

【0089】ホストIF102あるいはドライブIF103は、アクセス承認を受けるとデータ線210を通してアドレス、コマンド、データ(データの書き込み時のみ)を送出する。СМアクセス制御部104は、送られてきたアドレス、コマンド、データ(データの書き込み時のみ)をセレクタ302、パスIF301を介して、セレクタ部13に繋がるアクセスパス0:135に送出する。

【0090】セレクタ部13内のデータ転送制御部310は、制御線2:212によってアクセス開始の信号と、アクセス先のメモリコントローラ105を示す信号を受けると、4本の制御線2:212のどれからアクセス開始の信号が来たかと、アクセス先のメモリコントローラ105を示す信号によって、セレクタ304を切り

替え、制御線2:212によりCMアクセス制御部104内のデータ転送制御部310へアクセス承認の信号を返すとともに、制御線4:214によってメモリコントローラ105内のデータ転送制御部310へアクセス開始を示す信号と、アクセス先のメモリコントローラ105を示す信号を出す。

【0091】セレクタ部13は、送られてきたアドレス、コマンド、データ(データの書き込み時のみ)をアクセスパス0:135に繋がるパスIF301、セレクタ304、アクセスパス1:136に繋がるパスIF301を介して、メモリコントローラ105に繋がるアクセスパス1:136に送出する。

【0092】また、送られてきたアドレス及びコマンドはメモリコントローラ105へ送出するとともに、アドレス(adr)、コマンド(cmd)解析部305へ取り込み、2つのメモリコントローラ105の内のどちらにアクセスするかを調べ、制御線212のアクセス先のメモリコントローラ105を示す信号と比較し、異なる場合はエラーとみなし障害処理を行う。

【0093】メモリコントローラ105内のデータ転送制御部310は、制御線4:214によってアクセス開始の信号と、アクセス先のメモリコントローラ105を示す信号を受けると、制御線4:214によりセレクタ部13内のデータ転送制御部310へアクセス承認の信号を返す。また、送られてきたアドレス、コマンド、データ(データの書き込み時のみ)は、パケットバッファ303に一時格納する。

【0094】また、データ転送制御部310はアービトレーションを行い、2本のアクセスパス1:136のうちのどちらにメモリアクセス権を与えるかを決定する。

【0095】メモリアクセス権を与えられたパス側のパケットバッファ303から、アドレス、コマンドをアドレス (adr)、コマンド (cmd)解析部305へ取り込み、解析結果得られたメモリの制御情報をメモリ制御部307へ送出する。また、アクセス先メモリコントローラ105を調べ、自メモリコントローラと異なる場合はエラーとみなし障害処理を行う。

【0096】データの書き込み時は、パケットバッファ303内に格納したデータをセレクタ302、メモリIF308を介してメモリモジュール106へ書き込む。データの読み出し時は、メモリモジュール106からデータを読み出し、メモリIF308、セレクタ302、パスIF301を介してアクセスパス1:136へ送出する。

【0097】メモリモジュール106へのアクセスが終了すると、データ転送制御部310においてアクセス状況を示すステータスを生成し、セレクタ部13、CMアクセス制御部104を経由して、ホストIF102またはドライブIF103へ送出する。

【0098】本実施例では、CMアクセス制御部104

のデータ転送制御部310は、セレクタ302を切り替えた後、アクセス開始の信号をセレクタ部13に送出し、アクセス承認をホストIF102あるいはドライブIF103へ返すとしたが、そうした場合は、ホストIF102あるいはドライブIF103からアドレスが送られてくる前に、セレクタ部13からアクセス承認が返ってくるように、各部の処理時間を設定しなければならない。上記のように出来ない場合は、CMアクセス制御部104にバッファを設けるか、CMアクセス制御部104はセレクタ部13からアクセス承認が返ってくるまでホストIF102またはドライブIF103へアクセス承認を返さないようにする必要がある。

【0099】LSIのピンネックにより、全てのマイクロプロセッサ101からの制御線をメモリコントローラ105に接続できない場合は、上記のように、CMアクセス制御部104及びセレクタ部13の2個所で発生する競合解消のためのアービトレーションをセレクタ部13内のアービタ306においてまとめて行うことによっても、アクセス競合による3回の待ち時間を2回に減らすことが可能となる。それによって、キャッシュメモリ部14へのアクセス時間が短縮され、高いスループットのデータ転送を実現できる。

[0100]

【発明の効果】本発明によれば、チャネルIF部及びディスクIF部からキャッシュメモリ部へのアクセス時間を短縮することが可能となる。それによって、ディスクアレイ制御装置のデータ転送スループットが向上する。

【図面の簡単な説明】

【図1】本発明によるディスクアレイ制御装置の構成を示す図。

【図2】従来のディスクアレイ制御装置の構成を示す 図

【図 3 】従来のディスクアレイ制御装置の構成を示す 図。

【図4】本発明によるディスクアレイ制御装置の他の構成を示す図。

【図5】本発明によるディスクアレイ制御装置の他の構成を示す図。

【図 6 】本発明によるディスクアレイ制御装置内のCMアクセス制御部の構成を示す図。

【図7】本発明によるディスクアレイ制御装置内のCMアクセス制御部の他の構成を示す図。

【図8】本発明によるディスクアレイ制御装置内のセレクタ部の構成を示す図。

【図9】本発明によるディスクアレイ制御装置内のセレクタ部の他の構成を示す図。

【図10】本発明によるディスクアレイ制御装置内のキャッシュメモリ部の構成を示す図。

【図11】本発明によるディスクアレイ制御装置内のキャッシュメモリ部の他の構成を示す図。

【図12】本発明によるディスクアレイ制御装置の他の 構成を示す図。

【図13】本発明によるディスクアレイ制御装置のチャネル I F部の構成を示す図。

### 【符号の説明】

1 · · · ディスクアレイ制御装置、11 · · · チャネルIF 部、12 · · · ディスクIF部、13 · · · セレクタ部、14 ・・・キャッシュメモリ部、20・・・磁気ディスク装置、50・・・ホストコンピュータ、101・・・マイクロプロセッサ、102・・・ホストIF、103・・・ドライブIF、104・・・CMアクセス制御部、105・・・メモリコントローラ、106・・・メモリモジュール、110、111・・・内部バス、135・・・アクセスパス0、136・・・アクセスパス1、216・・・制御線6。

【図1】

**23** 1



【図2】

图2



【図3】



【図6】

210テータ程 (ホストル・または ドライブ Fへ) 300 300 300 300 212・制御部 301: (セレクタ部へ) 10+CMアクセス 301: (セレクタ部へ) 35・アクセス (スの

【図4】

【図5】

**2**25

図 4



【図7】

【図8】





【図9】

【図10】

図10





【図11】

図11



【図12】

図12



【図13】

図13

